草庐IT

Swift 继承

全部标签

c++ - 继承包含另一个派生类的 C++ 类

将下一个C++类作为问题的简化:structCar{virtualintget_price()=0;};structExpensiveCar:publicCar{intget_price(){/*..*/}voidapply_turbo(){/*..*/};};structCheapCar:publicCar{intget_price(){/*..*/}};structCarRetailer{virtualstd::vectorget_cars()=0;};structExpensiveCarsRetailer:publicCarRetailer{virtualstd::vectorg

c++ - 在 C++ 中使用 libCurl API 验证 SAIO(swift 多合一)

我正在致力于OpenStack,尤其是SwiftAllinOne(SAIO)。我需要使用C++和libcurl进行身份验证。通过终端使用curl我使用了这个命令(并且有效);curl-v-H'X-Auth-User:$SWIFTACCOUNT:$SWIFTUSER'-H'X-Auth-Key:$SWIFTPASSWORD'如何在C++中使用libcurl运行此命令? 最佳答案 将--libcurlcode.c附加到您的命令行,您将获得一个很好的第一个模板!CURLOPT_HTTPHEADER是curl_easy_setopt的选项你

c++ - 模板类实例化的多重继承以及对成员函数的访问

让我们看一下代码:templateclassS{public:voidadd(Cc){++cnt;}size_tsize()const{returncnt;}private:size_tcnt{};};structFoo1{};structFoo2{};structFoo3{};classZ:publicS,publicS,publicS{public:usingS::add;usingS::add;usingS::add;usingS::size;//(1)usingS::size;//(2)usingS::size;//(3)};用法是这样的:Zz;z.add(Foo1{});z.

c++ - 继承的构造函数和 "explicit is better than implicit"

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭7年前。Improvethisquestion良好编程风格的一个众所周知的原则是:“显式优于隐式”。继承的构造函数不是违背了这个原则吗?(包含基类的所有构造函数的单个using语句不是很明确,对吗?)

c++ - 从 enable_shared_from_this 返回 self 的 shared_ptr 继承的类的子类

我想知道是否有像这样的伪代码来做一些事情:classA:publicstd::enable_shared_from_this{public:std::shared_ptrgetPtr(){returnstd::static_pointer_cast(shared_from_this());}};classB:publicA{std::vectorcontainer;std::shared_ptraddChild(Achild){container.push_back(child);returngetPtr();}};classC:publicB{public:std::shared_p

c++ - 我可以继承模板类并将类型设置为我当前尝试继承的类的模板化子类吗?

糟糕的标题,我知道。我将举例说明:templatestructMemMapFileHashTable:MemMapFileStructured::kvp>{structkvp{uint32_tkey;ValTypeval;};MemMapFileHashTable(constchar*fileName,boolwrite=false,int64_tchunkB=65536):MemMapFileStructured(fileName,write,chunkB){}};所以我的想法是,我创建一个具有特定ValType的哈希表,该哈希表又具有具有特定ValType的kvp。要使用我正在继承

c++ - bisonc++ 多态继承

我正在尝试从野牛语法构建AST。Bison正确生成了解析器,但是当我尝试使用一些数学运算解析示例代码时,打印出以下错误:[Fatal]calling`.get()',butTagINTisencountered.调试后我注意到问题出在expr非终端中,产生式如下:expr:...|operator{$$=$1;}并且operator本身有以下产生式:operator:...|INTEGER{$$=newast::expression::IntASTNode(std::stoi(d_scanner.matched()));}我正在使用多态语义类型,expr和operator被标记为响应E

c++ - 将继承自某个类的所有类加为好友

这与其说是一个实际问题,不如说是一种求知欲。我想知道在C++中是否有一种方法可以执行以下操作:让A成为一个类。我想使B类与继承自A的所有类成为friend。先说再说:我明明知道友情是不能遗传的。我想做的是制作一个templatefriend声明,也许使用SFINAE,将B与每个类C交友,以便C继承自A。这样的事情有可能吗?我试图从最简单的情况开始:你能和所有其他类(class)交friend吗?显然我知道这没有任何意义,可以将事情公开,但也许从这个起点开始可以完善事情以仅选择那些继承自A的类。 最佳答案 解决方法是使用继承的“key

c++ - 非抽象但无状态的类对于多重继承是否与纯抽象类一样安全?

在大多数书籍和文章中,进行多重继承的唯一“安全”(或者至少是唯一建议的)方法是使用纯抽象基类(您可以称为虚拟接口(interface))的虚拟继承。原因主要是为了避免菱形继承(钻石问题),在菱形继承(钻石问题)中,人们可能会为数据成员的值或非纯虚函数的实现状态造成歧义。纯抽象基类不会同时遭受(没有数据成员,没有非纯虚拟)和虚拟继承甚至解决了基类实际内存地址的歧义。但是给出这样的解释:如果歧义仅来自“状态”的形式(例如数据成员、静态函数变量),那么就不是无状态非抽象(甚至可能具有所有“最终”方法)类作为多继承层次结构中的基类是否同样安全?我遗漏了什么可能的问题?PS:如果答案是“如果没有

c++ - C++ 中的继承 : define variables in parent-child classes

问题我正在寻找在父子类中定义变量的最佳方法,以便通过指向其父类的指针进行调用。这是协议(protocol):classBase{public:virtualvoidfunction()=0;};classA:publicBase{public:inta,b;A(inta_,intb_):a(a_),b(b_){};voidfunction(){//dosomething..}};classB:publicBase{public:inta,b;B(inta_,intb_):a(a_),b(b_){};voidfunction(){//dosomething..}};Base*elemen